草庐IT

android - 改造:@Field 和 @Body 有什么不同

全部标签

ruby-on-rails - Rails 中带有 text_field 的逗号分隔数组

我有一些用户可以有很多帖子,并且每个帖子都可以有很多标签。我已经使用帖子和标签之间的has_and_belongs_to_many关系实现了这一点。创建新帖子时,用户可以使用逗号分隔的值列表对其进行标记(很像在SO上发布新问题时)。如果任何标签尚不存在,则应自动创建。这是帖子的_fields.html.erb部分内容:f.object%>现在使用f.text_field:tags会生成带有[]文本的输入元素。我还没有在posts_controller.rb中使用标签,因为我不确定我应该如何从参数中获取和拆分字符串值:defcreate@post=current_user.posts.b

ruby - bundle.setup 和 bundle.require 有什么区别

来自thegemfilemanpage,我了解到有两种方法可以导入您在Gemfile中指定的gem。bundle.setup将“设置将gem添加到Ruby的加载路径”,而bundle.require将需要所有gem。这两种方法有什么区别?我应该在什么情况下使用其中之一? 最佳答案 Bundler.setup修改LOAD_PATH,因此您可以执行类似require'some_gem'的操作他们会工作的。它允许您“手动”获取gem。在Bundler出现之前,使用Rubygems,您可以通过执行require'rubygems'获得很多相

ruby - 选择一个随机选项,其中每个选项被选中的概率不同

假设给您三个“选项”,A、B和C。您的算法必须随机选择并返回一个。为此,只需将它们放在一个数组{A,B,C}中并生成一个随机数(0、1或2),这将是元素在返回数组。现在,这个算法有一个变体:假设A有40%的机会被选中,B有20%,而C40%。如果是这种情况,您可以采用类似的方法:生成一个数组{A,A,B,C,C}并生成一个随机数(0,1,2,3,4)选择要返回的元素。行得通。但是,我觉得效率很低。想象一下,将此算法用于大量选项。你会创建一个有点大的数组,可能有100个元素,每个元素代表1%。现在,这仍然不是很大,但假设您的算法每秒使用多次,这可能会很麻烦。我考虑过创建一个名为Slot的

ruby-on-rails - bundler Rails 在开发中需要不同的 gem

我正在尝试设置用于开发Railsgem的开发环境。我想在开发模式下从本地源加载gem,在生产模式下通过ruby​​gems加载gem。我想做如下事情:gem文件group:productiondogem'my_gem','1.0.0'endgroup:developmentdogem'my_gem',:path=>'~/apps/my_gem'end当我运行bundle命令时,bundler提示你不能加载同一个gem两次。有没有办法根据Rails环境要求不同版本的gem? 最佳答案 我遇到过同样的问题,并且是这样解决的:ifENV[

ruby-on-rails - 卡住 Rails 版本/gems 有什么意义?

这是什么意思?在一个项目的说明中,它说“卡住Railsgems”。这与卡住Rails版本有何不同?什么是卡住? 最佳答案 如果您使用的gem的作者之一引入了该gem的新版本,则新版本可能会引入向后不兼容的更改,从而破坏您的代码。卡住gem会将其放入应用程序的vendor文件夹中,并且不会自行自动更新。Rails将使用此版本的gem。这允许您为其他应用程序更新系统上的gem,同时让您唯一的应用程序使用您一直使用的gem版本,因此是稳定的。这也适用于railsgem本身,因为较新版本的rails最终可能会导致您的应用程序中的某些内容崩溃

ruby - 为什么我不能在 Ruby 的方法中访问局部变量?

我有一个名为test.rb的Ruby文件ff="ff"deftestputsffend我执行它,得到错误:test.rb:3:in`test':main:Object(NameError)的未定义局部变量或方法`ff'这是什么原因?有文档解释吗? 最佳答案 在test方法定义中无法访问ff的原因很简单,方法(使用def关键字创建)创建了一个新范围。与分别使用class和module关键字定义类和模块相同。在这种情况下,main(顶级对象)的作用几乎与作用域问题完全无关。请注意,如果您确实希望您的test方法能够访问在定义上下文中定义

ruby-on-rails - Standalone ruby​​ -- 如何从database.yml加载不同环境

我有一个修改数据库中记录的后台进程。模型使用如下方式连接到数据库:dbconfig=YAML::load(File.open('database.yml'))ActiveRecord::Base.establish_connection(dbconfig["development"])classClcar所有模型类的顶部都有这些行。我同意这是一种糟糕的做法。有没有更好的方法来连接到模型类?如何将连接传递给模型?我希望能够在不同的环境(比如“生产”)中运行我的后台进程。我该如何实现? 最佳答案 我会在您的后台进程开始时设置一次连接。一

ruby - sinatra 中的 Controller 是什么?

有人问我为什么“我要在我的View中创建复杂的Ruby变量。这些变量不应该由我的Controller声明吗?”我的sinatraController是我的.rb文件吗?我有一个.rb文件并查看View。 最佳答案 您可以通过在主.rb文件的顶部执行(在1.9.2中)设置Controller的概念Dir.glob("controllers/*.rb").each{|r|require_relativer}这将require_relative每个.rb文件在一个名为controllers/的文件夹中从那里您可以像以前在主.rb文件中那样

ruby - Ruby 中的 "and"、 "or"运算符背后有什么智慧吗?

我想知道为什么ruby​​给and、or的优先级低于&&、||和赋值运算符?有什么理由吗? 最佳答案 我猜这是Perl的直接继承。运算符or和and是后来在Perl5中添加的,用于需要较低优先级的特定情况。例如,在Perl中,我们希望||具有较低的优先级,这样我们就可以这样写:trytoperformbiglonghairycomplicatedaction||die;并确保||不会吞噬部分操作。Perl5引入了or,这是||的一个新版本,它具有低优先级,正是为了这个目的。Ruby中可以使用或但不能使用||的示例:value=pos

ruby-on-rails - 为什么 PG::UniqueViolation: ERROR: duplicate key value violates unique constraint?

我有一个模型Post,每次创建帖子时,我都希望同时创建一个新的Moderation实例。所以在post.rb中我使用回调after_save:create_moderation然后写一个私有(private)方法:...includeReportableafter_save:create_moderationprivatedefcreate_moderationself.create_moderation!(blog:Blog.first)end但是在创建提案时出现此错误:PG::UniqueViolation:ERROR:duplicatekeyvalueviolatesunique